|
In computability theory, a Turing reduction from a problem ''A'' to a problem ''B'', is a reduction which solves ''A'', assuming the solution to ''B'' is already known (Rogers 1967, Soare 1987). It can be understood as an algorithm that could be used to solve ''A'' if it had available to it a subroutine for solving ''B''. More formally, a Turing reduction is a function computable by an oracle machine with an oracle for ''B''. Turing reductions can be applied to both decision problems and function problems. If a Turing reduction of ''A'' to ''B'' exists then every algorithm for ''B'' can be used to produce an algorithm for ''A'', by inserting the algorithm for ''B'' at each place where the oracle machine computing ''A'' queries the oracle for ''B''. However, because the oracle machine may query the oracle a large number of times, the resulting algorithm may require more time asymptotically than either the algorithm for ''B'' or the oracle machine computing ''A'', and may require as much space as both together. The first formal definition of relative computability, then called relative reducibility, was given by Alan Turing in 1939 in terms of oracle machines. Later in 1943 and 1952 Stephen Kleene defined an equivalent concept in terms of recursive functions. In 1944 Emil Post used the term "Turing reducibility" to refer to the concept. A polynomial-time Turing reduction is known as a Cook reduction, after Stephen Cook. == Definition == Given two sets of natural numbers, we say is Turing reducible to and write : if there is an oracle machine that computes the characteristic function of ''A'' when run with oracle ''B''. In this case, we also say ''A'' is ''B''-recursive and ''B''-computable. If there is an oracle machine that, when run with oracle ''B'', computes a partial function with domain ''A'', then ''A'' is said to be ''B''-recursively enumerable and ''B''-computably enumerable. We say is Turing equivalent to and write if both and The equivalence classes of Turing equivalent sets are called Turing degrees. The Turing degree of a set is written . Given a set , a set is called Turing hard for if for all . If additionally then is called Turing complete for . 抄文引用元・出典: フリー百科事典『 ウィキペディア(Wikipedia)』 ■ウィキペディアで「turing reduction」の詳細全文を読む スポンサード リンク
|